﻿using System;
using System.Collections;
using System.Collections.Generic;
using System.Data;
using System.Data.Common;
using SIM.Geo.BE;
using System.Linq;

namespace SIM.Geo.DA
{
    public class DATexturaRoca:Base
    {
        #region Metodos
        /// <summary>
        /// Método que devuelve la lista de texturas de roca
        /// </summary>
        /// <returns></returns>
        public List<TexturaRoca> ListarTexturaRoca()
        {
            return this.Context.TexturaRoca.ToList();
        }
        /// <summary>
        /// Método para insertar una textura de roca
        /// </summary>
        /// <param name="TexturaRoca"></param>
        /// <returns></returns>
        public int InsertarTexturaRoca(TexturaRoca texturaroca)
        {
            this.Context.TexturaRoca.AddObject(texturaroca);
            this.Context.SaveChanges();
            return texturaroca.CodigoTexturaRoca;
        }
        /// <summary>
        /// Método para modificar un textura de roca
        /// </summary>
        /// <param name="TexturaRoca"></param>
        public void ModificarTexturaRoca(TexturaRoca texturaroca)
        {
            this.Context.TexturaRoca.Attach(texturaroca);
            this.Context.ObjectStateManager.ChangeObjectState(texturaroca, EntityState.Modified);
            this.Context.SaveChanges();
        }
        /// <summary>
        /// Método para eliminar tipo de roca
        /// </summary>
        /// <param name="TexturaRoca"></param>
        public void EliminarTexturaRoca(TexturaRoca texturaroca)
        {
            this.Context.TexturaRoca.Attach(texturaroca);
            this.Context.ObjectStateManager.ChangeObjectState(texturaroca, EntityState.Deleted);
            this.Context.SaveChanges();
        }
        /// <summary>
        /// Método que busca por nombre tipo de roca
        /// </summary>
        /// <param name="nombre"></param>
        /// <returns></returns>
        public List<TexturaRoca> BuscarTexturaRoca(string nombre)
        {
            return this.Context.TexturaRoca.Where(x => x.Descripcion.StartsWith(nombre)).ToList();
        }
        /// <summary>
        /// Método que devuelve tipo de roca por codigo
        /// </summary>
        /// <param name="codigoTexturaRoca"></param>
        /// <returns></returns>
        public TexturaRoca ObtenerTexturaRoca(int codigoTexturaRoca)
        {
            return this.Context.TexturaRoca.Where(x => x.CodigoTexturaRoca.Equals(codigoTexturaRoca)).FirstOrDefault();
        }
        #endregion
       
    }
}
